import axios from "axios";
import { Message } from "@arco-design/web-vue";

// 是否是开发环境
export const isDev = process.env.NODE_ENV === "development";


const myAxios = axios.create({
  baseURL: isDev ? "http://localhost:8101" : "http://120.76.241.179:8101",
  timeout: 60000,
  // 允许携带cookie
  withCredentials: true,
});

// 添加请求拦截器
axios.interceptors.request.use(
  function (config) {
    // 在发送请求之前做些什么
    return config;
  },
  function (error) {
    // 对请求错误做些什么
    return Promise.reject(error);
  }
);

// 添加响应拦截器
axios.interceptors.response.use(
  function (response) {
    // 2xx 范围内的状态码都会触发该函数。
    // 对响应数据做点什么
    console.log("响应拦截器", response);
    //获取返回数据
    const { data } = response;
    // 提示未登录报错
    if (data.code === 40100) {
      //不是获取用户信息接口，或者不是登录页面，则跳转到登录页面
      if (
        !response.request.responseURL.includes("/user/get/login") &&
        !window.location.pathname.includes("/user/login")
      ) {
        Message.warning("请先登录");
        window.location.href = `/user/login?redirect=${window.location.href}`;
      }
    }
    return response;
  },
  function (error) {
    // 超出 2xx 范围的状态码都会触发该函数。
    // 对响应错误做点什么
    return Promise.reject(error);
  }
);

export default myAxios;
